<template>
  <el-main class="bg table_wrap">
    <el-form label-position="right" :model="query" class="form p_4" label-width="120">
      <el-row class="rows row1">


        <el-col :xs="24" :sm="24" :lg="8" class="el_form_search_wrap">
          <el-form-item label="用户姓名">
            <el-input v-model="query.user_name"></el-input>
          </el-form-item>
        </el-col>
        <el-col :xs="24" :sm="24" :lg="8" class="el_form_search_wrap">
          <el-form-item label="预订编号">
            <el-input v-model="query.booking_number"></el-input>
          </el-form-item>
        </el-col>
        <el-col :xs="24" :sm="24" :lg="8" class="el_form_search_wrap">
          <el-form-item label="路线编号">
            <el-input v-model="query.route_number"></el-input>
          </el-form-item>
        </el-col>
        <el-col :xs="24" :sm="24" :lg="8" class="el_form_search_wrap">
          <el-form-item label="审核状态">
            <el-select v-model="query.examine_state">
              <el-option value="">全部</el-option>
              <el-option value="未审核">未审核</el-option>
              <el-option value="已通过">已通过</el-option>
              <el-option value="未通过">未通过</el-option>
            </el-select>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row class="rows row2">
        <el-col :xs="24" :sm="24" :lg="24" class="search_btn_wrap search_btns">
          <el-col :xs="24" :sm="10" :lg="8" class="search_btn_1 search_btn_wrap_1 btns">
            <el-button type="primary" @click="search()" class="search_btn_find">查询</el-button>
            <el-button @click="reset()" style="margin-right: 74px;" class="search_btn_reset">重置</el-button>
            <el-button v-if="user_group == '管理员' || $check_action('/unsubscribe_record/table','del') || $check_action('/unsubscribe_record/view','del')" class="search_btn_del" type="danger"
                       @click="delInfo()">删除
            </el-button>
          </el-col>

        </el-col>
      </el-row>
    </el-form>
    <el-table :data="list" @selection-change="selectionChange" @sort-change="$sortChange" style="width: 100%" id="dataTable">
      <el-table-column fixed type="selection" tooltip-effect="dark" width="55">
      </el-table-column>
      <el-table-column prop="unsubscribe_from_account" @sort-change="$sortChange" label="退订账号"
                       v-if="user_group == '管理员' || $check_field('get','unsubscribe_from_account')" min-width="200">
        <template slot-scope="scope">
          {{ get_user_unsubscribe_from_account(scope.row['unsubscribe_from_account']) }}
        </template>
      </el-table-column>
      <el-table-column prop="user_name" @sort-change="$sortChange" label="用户姓名"
                       v-if="user_group == '管理员' || $check_field('get','user_name')" min-width="200">
      </el-table-column>
      <el-table-column prop="user_phone_number" @sort-change="$sortChange" label="用户电话"
                       v-if="user_group == '管理员' || $check_field('get','user_phone_number')" min-width="200">
      </el-table-column>
      <el-table-column prop="booking_number" @sort-change="$sortChange" label="预订编号"
                       v-if="user_group == '管理员' || $check_field('get','booking_number')" min-width="200">
      </el-table-column>
      <el-table-column prop="route_name" @sort-change="$sortChange" label="路线名称"
                       v-if="user_group == '管理员' || $check_field('get','route_name')" min-width="200">
      </el-table-column>
      <el-table-column prop="route_number" @sort-change="$sortChange" label="路线编号"
                       v-if="user_group == '管理员' || $check_field('get','route_number')" min-width="200">
      </el-table-column>
      <el-table-column prop="unsubscribe_time" @sort-change="$sortChange" label="退订时间"
                       v-if="user_group == '管理员' || $check_field('get','unsubscribe_time')" min-width="200">
        <template slot-scope="scope">
          {{ $toTime(scope.row["unsubscribe_time"], "yyyy-MM-dd hh:mm:ss") }}
        </template>
      </el-table-column>
      <el-table-column prop="reason_for_unsubscribing" @sort-change="$sortChange" label="退订原因"
                       v-if="user_group == '管理员' || $check_field('get','reason_for_unsubscribing')" min-width="200">
      </el-table-column>
      <el-table-column prop="refund_amount" @sort-change="$sortChange" label="退款金额"
                       v-if="user_group == '管理员' || $check_field('get','refund_amount')" min-width="200">
      </el-table-column>

      <el-table-column label="审核状态" prop="examine_state">
      </el-table-column>

      <el-table-column label="审核回复" prop="examine_reply">
      </el-table-column>


      <el-table-column sortable prop="create_time" label="创建时间" min-width="200">
        <template slot-scope="scope">
          {{ $toTime(scope.row["create_time"], "yyyy-MM-dd hh:mm:ss") }}
        </template>
      </el-table-column>

      <el-table-column sortable prop="update_time" label="更新时间" min-width="200">
        <template slot-scope="scope">
          {{ $toTime(scope.row["update_time"], "yyyy-MM-dd hh:mm:ss") }}
        </template>
      </el-table-column>


      <el-table-column fixed="right" label="操作" min-width="120"
                       v-if="user_group == '管理员' || $check_action('/unsubscribe_record/table','set') || $check_action('/unsubscribe_record/view','set') || $check_action('/unsubscribe_record/view','get') || $check_action('//table','add') || $check_action('//view','add')">


        <template slot-scope="scope">
          <router-link class="el-button el-button--small is-plain el-button--success" style="margin: 5px !important;"
                       v-if="user_group == '管理员' || $check_action('/unsubscribe_record/table','set') || $check_action('/unsubscribe_record/view','set') || $check_action('/unsubscribe_record/view','get')"
                       :to="'./view?' + field + '=' + scope.row[field]"
                       size="small">
            <span>详情</span>
          </router-link>
        </template>
      </el-table-column>

    </el-table>

    <!-- 分页器 -->
    <div class="mt text_center">
      <el-pagination @size-change="handleSizeChange" @current-change="handleCurrentChange"
                     :current-page="query.page" :page-sizes="[7, 10, 30, 100]" :page-size="query.size"
                     layout="total, sizes, prev, pager, next, jumper" :total="count">
      </el-pagination>
    </div>
    <!-- /分页器 -->


    <div class="modal_wrap" v-if="showModal">
      <div class="modal_box">
        <!-- <div class="modal_box_close" @click="closeModal">X</div> -->
        <p class="modal_box_title">重要提醒</p>
        <p class="modal_box_text">当前有数据达到预警值！</p>
        <div class="btn_box">
          <span @click="closeModal">取消</span>
          <span @click="closeModal">确定</span>
        </div>
      </div>
    </div>


  </el-main>
</template>
<script>
import mixin from "@/mixins/page.js";

export default {
  mixins: [mixin],
  data() {
    return {
      // 弹框
      showModal: false,
      // 获取数据地址
      url_get_list: "~/api/unsubscribe_record/get_list?like=0",
      url_del: "~/api/unsubscribe_record/del?",

      // 字段ID
      field: "unsubscribe_record_id",

      // 查询
      query: {
        "size": 7,
        "page": 1,
        "user_name": "",
        "booking_number": "",
        "route_number": "",
        "examine_state": "",
        "login_time": "",
        "create_time": "",
        "orderby": `create_time desc`
      },

      // 数据
      list: [],
      // 用户列表
      list_user_unsubscribe_from_account: [],
    }
  },
  methods: {
    // 关闭弹框
    closeModal() {
      this.showModal = false;
    },

    get_list_before(param) {
      var user_group = this.$store.state.user.user_group;
      if (user_group != "管理员") {
        let sqlwhere = "(";
        if (user_group == "注册用户") {
          sqlwhere += "unsubscribe_from_account = " + this.$store.state.user.user_id + " or ";
        }
        if (sqlwhere.length > 1) {
          sqlwhere = sqlwhere.substr(0, sqlwhere.length - 4);
          sqlwhere += ")";
          param["sqlwhere"] = sqlwhere;
        }
      }
      return param;
    },


    /**
     * 获取注册用户用户列表
     */
    async get_list_user_unsubscribe_from_account() {
      var json = await this.$get("~/api/user/get_list?user_group=注册用户");
      if (json.result && json.result.list) {
        this.list_user_unsubscribe_from_account = json.result.list;
      } else if (json.error) {
        console.error(json.error);
      }
    },

    get_user_unsubscribe_from_account(id) {
      var obj = this.list_user_unsubscribe_from_account.getObj({"user_id": id});
      var ret = "";
      if (obj) {
        ret = obj.nickname + "-" + obj.username;
        // if(obj.nickname){
        // 	ret = obj.nickname;
        // }
        // else{
        // 	ret = obj.username;
        // }
      }
      return ret;
    },
    deleteRow(index, rows) {
      rows.splice(index, 1);
    }

  },
  created() {
    this.get_list_user_unsubscribe_from_account();
  }
}
</script>

<style type="text/css">
.bg {
  background: white;
}

.form.p_4 {
  padding: 1rem;
}

.form .el-input {
  width: initial;
}

.mt {
  margin-top: 1rem;
}

.text_center {
  text-align: center;
}

.float-right {
  float: right;
}


.modal_wrap {
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 9999999999;
}

.modal_wrap .modal_box {
  width: 400px;
  height: 200px;
  background: url("../../assets/modal_bg.jpg") no-repeat center;
  background-size: cover;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-left: -200px;
  margin-top: -100px;
  border-radius: 10px;
}

.modal_wrap .modal_box .modal_box_close {
  font-size: 20px;
  position: absolute;
  top: 10px;
  right: 10px;
  cursor: pointer;
}

.modal_wrap .modal_box .modal_box_title {
  text-align: center;
  font-size: 18px;
  margin: 16px auto;
  color: #fff;
  border-bottom: 1px solid rgba(117, 116, 116, 0.5);
  padding-bottom: 16px;
  width: 356px;
}

.modal_wrap .modal_box .modal_box_text {
  text-align: center;
  font-size: 15px;
  color: #fff;
  margin-top: 25px;
}

.modal_wrap .modal_box .btn_box {
  display: flex;
  flex-direction: row;
  justify-content: center;
  margin-top: 42px;
}

.modal_wrap .modal_box .btn_box span {
  display: inline-block;
  width: 80px;
  height: 30px;
  line-height: 30px;
  text-align: center;
  border: 1px solid #ccc;
  font-size: 14px;
  cursor: pointer;
  color: #fff;
}

.modal_wrap .modal_box .btn_box span:nth-child(2) {
  background: #409EFF;
  color: #fff;
  border-color: #409EFF;
  margin-left: 15px;
}
</style>
